<!doctype html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0"
        name="viewport">
  <meta content="ie=edge" http-equiv="X-UA-Compatible">
  <title>Document</title>

  <script defer src="https://unpkg.com/alpinejs@3.x.x/dist/cdn.min.js"></script>
</head>
<body>
<div x-data>
  <button @click="$store.darkMode.toggle()">Toggle Dark Mode</button>

  <div :class="$store.darkMode.on && 'bg-black'">Some contents</div>
</div>

<script>
document.addEventListener('alpine:init', () => {
  Alpine.store('darkMode', {
    on: false,

    toggle() {
      this.on = !this.on
    }
  })
})
</script>

<div x-data>
  <button @click="$store.on = ! $store.on">Toggle Dark Mode</button>

  <div :class="$store.on && 'bg-black'">Some contents</div>
</div>
<script>
document.addEventListener('alpine:init', () => {
  Alpine.store('on', false)
});
</script>
</body>
</html>